import java.util.ArrayList;
import java.util.List;

public class Solution228 {
    /**
     * 给定一个无重复元素的有序整数数组，返回数组区间范围的汇总。
     *
     * 示例 1:
     *
     * 输入: [0,1,2,4,5,7]
     * 输出: ["0->2","4->5","7"]
     * 解释: 0,1,2 可组成一个连续的区间; 4,5 可组成一个连续的区间。
     *
     */
    public List<String> summaryRanges(int[] nums) {
        int head = nums[0];
        int tail = nums[0];
        List<String> res = new ArrayList<>();
        for (int i = 1; i < nums.length; i++) {
            if (nums[i] - nums[i - 1] != 1) {
                if (tail == head) {
                    res.add("" + head);
                } else {
                    res.add("" + head + "->" + tail);
                }
                head = nums[i];
            }
            tail = nums[i];
        }
        if (tail == head) {
            res.add("" + head);
        } else {
            res.add("" + head + "->" + tail);
        }
        return res;
    }
}
